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1, Steven Robert Beckhardt, hereby declare as folbws: 

I am an inventor of the Invention claimed in the above-identified patent application. 

I have reviewed the Office Action of August 14, 2002. for the subject application, and 1 
have also reviewed the current Status of the claims. 

The publication by Sybex titled, ♦Hlie ABCs of Outlook 97". dated March 17, 1997, Is 
alleged to describe subject matter similar to that disctosed m the subject patent 
application. 

The publication by PC World Magazine titled "The Future is Briglit for Microsoft 
Outlook 97" dated November 1, 1996, is also alleged to describe subject matter similar to 
that disclosed in the sabject patent applicatioa 

"Ruiming Microsoft Windows" by Microsoft Press - dated June 25, 1997, is also alleged 
to describe subject matter similar to that disclosed in the above-identified patent 
application. 
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6. Prior to November 1 , 1996, Douglas Walter Conmy, John Banks-Binici, Robert Slapikoff 
and I collectively completed the invention claimed in the above-identified patent 
application. 

7. Prior to November 1, 1 996, Douglas Water Conmy, John Banks-Binici, Robert Slapikoff 
and 1 conceived of an reduced the invention to practice. 

8. Since the claimed invention is incorporated in Lotus Notes version 4.50, operable on a 
personal cotnputer, for example, in communication with a computer network, which was 
released on December 4, 1996, the claimed invention was completed and reduced to 
practice well before this date, as such software releases usually take^ at a minimum, more 
than a year to prepare. 

9. As evidence of the invention bemg completed and reduced to practice prior to November 
U 1996* a listing of the soun:e code files which provides the features of the claimed 
invention is set out on Exhibit A, This information was obtained from a software archive 
from the assignee's engineering department. 

10. The source code file nsfi^schedule.c, corresponds to a process by which one or more 
invitee profiles for one or more potential mvitees of the system are stored. Each profile 
includes information regarding available and unavailable times for that user. 
Specifically, the process enables a server to collect a user's available time known as 
'^working hours'* (Le., free-time), as well as time that the user has btocked off (i,e,, busy- 
time) into a database/file for optimized retrieval The information may be distributed 
acix)ss multiple servers as is made available to requesting individuals. This process also 
monitors a user*s accepted and scheduled appointments and reflects them in tibe database. 

1 1 . The source code files nsf^schedule.c, client/clschreLC and scrver/scschret,c correspond to 
a process by which a request for allocatfon of a time interval for the one or more potential 
invitees is received, A Lotus Notes client or a Lotus Domino server may obtain the 
availability of one or more users by calling the application-program-interface (API) 

2 
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functions SchRetrfeve (retrieve a schedule) or SchSivRetrieve contained in the above- 
noted source code files. 

12 The fiinction SchRetrieve is a function which synchronously retrieves a local or remote 
schedule by asking the caller's home server for the schedule. The only time that local 
busy time is used is when the client is in a "Disconnected" mode, which is specified 
■ through a location document, aherwisc, the API wUl route all lookup requests to the 
users home server for processing- Exhibit B includes fiirthcr docuitwntation for tho 
SchRetrieve function, 

1 3. SchSrvRetrieve is a fonction which, upon being used on a server, synchronously retrieves 
local or remote schedules from the proper fenout servers. Upon the SchSrvRetrieve 
being used on a client, only locaUy available information is retrieved in busytime.nsf. 
Exhibit C includes farther documentation for the SchSrvRetrieve function. 

14. The souice-code files nsflfschedulcc, nsl/schcntnr.c. ns^schobj.c and nsf/schods.c 
correspond to a process by which invitee profiles for the one or more potential invitees 
are gathered. This is initialed in response to the request for the aUocation of a time 
interval for the one or more invitees, and the information is obtained from the stored 
invitee profile data. The data is represented in memory by schcntnr.o and scbobj.c, in a 
SchContainer. Access to the data within the container is made possible via the API 
fijnctions SchContainer.GctFirstSchedule and SchContainer_QelNextSchedule. 

15. SchContainer_GetFirstSchedule. This function is used to get a 
handle to the first schedule object in a container (sec also Exhibit 

D) . 

16. SchContainer_GetN6XtSchedule. This API function is used to get a 
handle to tlie a next schedule object in a container (see also Exhibit 

E) . 
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17, Source code files schui/bsysugg.cpp and misc/timelist.c correspond to a process for 
determining whether potential invitees are available during the requested time inlervaL 
This process specifically determines the availability of one or more users by first 
requesting their freetime and busyiimc (sec part 10 above). Once this information is 
obtained^ the source code provides further processing of this data via a time weighting 
algorithm designed to find a period of time where all users arc available, and, if not 
possible, a time where most of the users are available. 

1 8, Source code schui/bsyUst.cpp, schui/bsylistw.cpp, schui/freetime-cpp and 
wmisc/drawCimexpp enables a process by which results of the determination (see part 17 
above) are displayed by permitting a user to select from at least three results viewing 
options including a viewing option displaying the one or more potential invitees tiiat are 
available, a viewing option displaying the one or more potential invitees that are not 
available and a viewing option displaying the one or more potential invitees whose 
schedule could not be found, and then displaying the results accordii^ to the option 
selected. 

19. Using an email program, in the present invention^ an email is sent from an event 
coordinator which includes event information for scheduling an event where the event 
information spcci^ing a list of invitees, a date, a start time, and an end time and/or a 
duration which determines the end time. 

20. While tlie majority of the files were last modified prior to November 1, 1996, several of 
them were changed either on 1 1/12/96 and 1 1/15/96 (3 files). To that end, at that point in 
our development cycle, given that the fmal release was well underway (released 
December 4, 1996), the changes made to those files were oafy made to fix software bugs, 
and did not add or extend any of the existing functionality or capabilities of tlie invention. 
This can be fiirther evidenced by the following development comment files regarding 
changes made to those files around that time as shown in Exhibit F. 
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21. I hereby declare that all statements made herein of my own knowledge are true and that 
all statements made on information and belief are believed to be (rue; and further that 
these statements were made wMi the knowledge that wiUfiil false statrnients and the like 
so made are punishable by fine or imprisonment, or both under Section 1001 of Title 1 8 
of the United Slates Code and thai such willfiil and felse statements may jeopardize the 
validity of the application or any patent issued thereon. 



Steven Robert Bcckhardt 
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m: \v4x\v4.5\cllent\clschrot-c 

m: \v4x\v4 . 5\misc\timelist . c 

m: \v4x\v4 _ 5\nsf \schcntnr . c 
m: \v4x\v4 , 5\nsf \schedule- C 
m: \v4x\v4-5\nsf \schobj -c 
iQ;\v4x\v4.5\nsf \schods-c 
m: \v4x\v4 .5\nsf\schrqst-c 

m: \v4x\v4 .5\schedule\iiiain-c 

m:\v4x\v4 .5\schui\bsydata-cpp 
m: \t4x\v4 , SNachuiVbsyinvit . cpp 
m; \v4x\v4.5\schui\bsylist -cpp 
m: \v4x\v4 . 5\schui\bsylist -hpp 
m: \v4it\v4 . 5\schui\bsylistw.cpp 
tnz \v4x\v4 . 5\schui\bsysugg- cpp 
m: \v4x\v4 -5\£C:hui\frcGtiine.cpp 

m: \v4x\v4 . 5\scrver \svschret , c 

m: \v4x\v4 . 5\winlsc\drawtime,c 



EXHIBIT A 



20121 


10-23- 


-1996 


10:14:56 


70828 


11- 


15- 


■1996 


11:27: 34 


55805 


11- 


•12- 


1996 


16:42 :50 


171683 


11- 


■12- 


•1996 


aS:37r 06 


4128Q 




•24- 


'1996 


15: 12:18 


27287 


10- 


•12- 


■1996 


14:07:42 


23671 


10- 


•22- 


•1996 


13:51:10 


106705 


10- 


•31- 


•1996 


7:13:08 


21145 


10- 


'31- 


-1996 


11;52;30 


17617 


10- 


■29- 


-1996 


11:55:52 


16207 


10- 


-29-1996 


13:05:06 


7052 


10- 


-29-1996 


13:06:02 


9376 


10- 


-15- 


-1996 


17:12:02 


13703 


10- 


-22- 


-1996 


15:09:44 


28819 


10- 


-22- 


-1996 


18:41:48 


13242 


10-14-1996 


18:10:38 


8266 


9- 


-16- 


-1996 


13:29:08 



6 



01/21/2003 16:49 FAX 212 



756 



MINTZ, LEVIN 




Sioos 



Douglas Walter CONMY, ct >L 



EXHIBIT B 



Initial Release 4.5 



FuncUon : Calendaring and Scheduling 



SchRetrieve - Retrieve a schedute. 



^include <schedule.h> 

STATUS LNPUBUC SchRGtricve( 
UNID FAR*pApptUnid, 
TIMEDATE FAR *pApptOfigDate, 
DWORD dwOptions, 
TIMEDATE_PAIR FAR *plntewal, 
LIST FAR 'pNameS. 
HCNTNR FAR *rethCntnr, 
void FAR *MustBeNull1, 
void FAR *MustBeNuU2, 
void FAR* FAR *MustBeNull3); 

Description : 

Synchronously retrieves a local or remote schedule t>y asking the 
caller's home sen/erfor the schedule. 

The ONLY time that local busy time Is used is when the diert is In 
the Disconnected mode which is specified through the location document 
Otherwise, the API will route ALL lookup requests to the users home server 
for procesdng. 

Parameters : 



pApptUnld - Ignore this UNIO in computatjons- 
pApptOrigDate - Reserved. Must be set to NULL. 
dwOptlons - Option flags: 

SCHRQSTjCOMPOSITE retum composite schedule 
SCHRQST EACHPERSON retum each person's schedule 



SCHRQSTIforCEREMOTE force remote even if you are usmg woricstation 



pinterval - pointer to a TCWIEDATE^PAIR structure that specifies the 
range over which the free time search should be performed- In typical 
schedunng applications, this might be a range of 1 day or 5 days. 



SCHRQST"loCAL do only local lookup 



email 
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work. This (ist can be conveniently built with the textlist package. 
WIu$t8eNuil1 - Thi$ parameter must be NULL 
MuslBeNuIi2 - This parameter must be NULL 
Mu5tBeNull3 - This parameter must be NULL 
Output : 

(routine) - NOERROR - Successfully retrieved a schedule, 
ERR_xxx - There are many possible errors, it Is best to use the code In a 
call to OSLoadString and display/log the error for the user as your default 
error handling. 



rethCntnr - Handle of schedule container results are returned in. tf 
*fethCntnr is NULLHANDLE. then the container will be allocated by thfs 
call, tf it is not NULLHANDLE then the caller has allocated it and is 
responsible for freeing it on dll emxs. 



See Sample Program ; 

MISCVSCHEDULE 

See Also : 

SchContainer_Free 
SchSrvRetrieve 



SCHRQST XXX 
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EXHIBIT C 

Initial Release 4.5 
Function : Calendaring and Scheduling 
SchSn/Retrieve - Retrieve a schedule. 



include <6Ch6dule.h> 

STATUS LNPUBLIC SchSn^RetrievG{ 
LIST FAR *pCEentNames. 
UNID FAR *pApptUnid, 
TIMEDATE FAR *pApptOrigOate. 
DWORD dwOptions, 
TIMEDATE_PAIR FAR *plnten/al, 
LIST FAR *pNames, 
HCNTNR FAR *rethCnlnr); 

Description : 

When this call is made on a sewer, it synchronously retrieves 
local or remote schedules from the proper fenout servers. When this can is 
made on a client, it retrieves only locally available information m 
busytime-naf 

This container must be deallocated by the caWer u^ng SchContainer_Free. 
Parameters : 
Input : 

pClienlNames - List of users making query. 
pApptUnid - Ignore this UNID in computations. 

pApptOrigDate - This is the original start date of the appointment to 
ignore. This is only here for Organizer 2.^ compatibility. 

dwOptions - OpOon flags: . 
SCHRQST.COMPOSITE default if dwOptions is 0 
SCHRQST EACHPERSON return each person's schedule 

SCHRQST^LOCAL only look up sdiedules locally 

plnterval - Pointer to a TlMEDATE_PAlRslrudure that specifiefi the ra^^ 
over which the free time search shouJd be perfomied. In typical scheduling 
applications this might be a range of 1 day or 5 days. 

oNames - Poinlerto a list of distinguished names whose schedule shoutd 
be searched. This Est is in TEXT^LlST format without the datatype word. 
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This Ust can be build with the textlist package (e.g. UstAUocate) 
Output: 

(routine) - NOERROR - Successfully retrieved a schedule. 
ERR_xxx - There are many possible errors. It is best to use the code in a 
call to OSLoadString and display/log the en*orforthe user as your default 
error handiing. 



rethCntnr - Handle of the container that results are returned in. 



See Also : 

SchContalner_Free 
SCHRQSTjooc 
Sch Retrieve 
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EXHIBIT D 



Initial Release 4.5 



Function : Calendaring and Scheduling 



SchContaineCGetFlrstSchedule - Get first schedule object in a container 



ffindude <schedule.h> 

STATUS LNPUBLIC SchContalner_G6tFirstSchedule( 
HCNTNR hCntnr, 
HSCHEDULE FAR *rethOtji. 
SCHEDULE FAR * FAR *r^Schedule); 

Description : 

This function is used to get a handle to the first schedule Object 
in a container. 

Parameters : 

Input : 

hCntnr - The container handle. 
Output : 

(routine) - NOERROR - Successfully got first schedule. 
ERR_xxx - There are many posable errors. It is best to use the code in a 
call to OSLoadString and display/log the error for the user as your default 
error handling. 



rethObj - Points to where we return the handle to the schedule. 
relpScheduIe - Points to where we return a pointer to the actual data. 



See Sample Program : 
M1SC\SCHEDULE 

See Also : 

SchContainer^GetNextSchedule 
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EXHIBIT E 

Initial Release 4.5 



Data Type : Calendaring and Scheduling 
SCHEDULE - Data structure for a schedule. 



#lndud€! <$chedule.h> 

Oefinitien : 

typedef struct { 
DWORD reserved^]; 

□BID dbReplicalD; r Users mail file replica ID */ 
TIMEOATE_PAIR Interval; r events etc. are in this 
interval */ 

DWORD dwErrGatewayj r gateway eror retrieving this 
schedule */ 

STATUS erron /* error retrieving this 
schedule */ 

WORD wReserved; r unused at this time V 
WORD wOwnerNameSize; r size of owner name 
(includes terni.) V 

r followed by owner name V 

} SCHEDULE; 

Description : 

Data structure for a schedule. 

See Sample Program : 

MISaSCHEDULE 

See Also : 

SchContainer_GetFiratSchedule 
SchContainer^GetNextSchedule 
SchContainer^FindSchedule 
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EXHIBIT F 

From ktt\dwc.txt, comments from Douglas Comny: 
Build 145.1 

DWC 1 1/02(96) misc: Fixed incorrect profile display when the date/time 
crosses DST. [timelist.c] (#DCOY3B2ML6) 

From kit\jeb.txt, comments from John Banks-Bbici: 

Build 145 

JEB 9/19/96 nsf (145) check hCntnr for NULL before calling 
OSLock. Fix client to handle ctrl-brcak (#MM0039M2EL) 
[schobj.c][schods.c] [schcnlnr.c] [clicnt\clschret.c] 

JEB 9/19/96 nsf (145) don't infinitely loop on Calendar domain if it 
is same as current domain (#MM0039M27U) (scheduler) 

JEB 1 0/4/96 bcase (145) allow NEXT button to work right when 

replicating free time info (#DCOY3 A2SZK) 
tnsf\schedule.c][serveT\svschret.c][bcase\bcdsched-c] 



